Add region details in gtk_widget_get_path().
authorCarlos Garnacho <carlosg@gnome.org>
Fri, 23 Apr 2010 00:36:47 +0000 (02:36 +0200)
committerCarlos Garnacho <carlosg@gnome.org>
Sat, 4 Dec 2010 14:37:09 +0000 (15:37 +0100)
gtk/gtkwidget.c

index e4e3e32b86ee42cfd2b71b071c647235faaffabe..8fcff94b67bf684f96279a84b1b9c082baa6ae99 100644 (file)
@@ -13182,17 +13182,53 @@ _gtk_widget_set_height_request_needed (GtkWidget *widget,
 GtkWidgetPath *
 gtk_widget_get_path (GtkWidget *widget)
 {
+  GtkStyleContext *context;
   GtkWidgetPath *path;
+  GtkWidget *parent;
+  GList *regions, *reg;
 
   g_return_val_if_fail (GTK_IS_WIDGET (widget), NULL);
   g_return_val_if_fail (GTK_WIDGET_REALIZED (widget), NULL);
 
+  parent = widget->priv->parent;
+
   path = gtk_widget_path_new ();
+  gtk_widget_path_prepend_type (path, G_OBJECT_TYPE (widget));
+  regions = reg = NULL;
 
-  while (widget)
+  if (widget->priv->name)
+    gtk_widget_path_iter_set_name (path, 0, widget->priv->name);
+
+  context = g_object_get_qdata (G_OBJECT (widget),
+                                quark_style_context);
+
+  if (context)
+    regions = reg = gtk_style_context_list_child_classes (context);
+
+  while (reg)
     {
-      gtk_widget_path_prepend_type (path, G_OBJECT_TYPE (widget));
-      widget = widget->parent;
+      GtkChildClassFlags flags;
+      const gchar *region_name;
+
+      region_name = reg->data;
+      reg = reg->next;
+
+      gtk_style_context_has_child_class (context, region_name, &flags);
+      gtk_widget_path_iter_add_region (path, 0, region_name, flags);
+    }
+
+  g_list_free (regions);
+
+  while (parent)
+    {
+      guint position;
+
+      position = gtk_widget_path_prepend_type (path, G_OBJECT_TYPE (parent));
+
+      if (parent->priv->name)
+        gtk_widget_path_iter_set_name (path, position, parent->priv->name);
+
+      parent = parent->priv->parent;
     }
 
   return path;